package weektwo;

import java.util.ArrayList;
import java.util.List;

public class FindSubSets_78 {
    private List<List<Integer>> ans;
    private List<Integer> list;
    public List<List<Integer>> subsets(int[] nums) {
        ans = new ArrayList<List<Integer>>();
        list = new ArrayList<Integer>();
        findSubsets(nums, 0);
        return ans;
    }

    private void findSubsets(int[] nums, int index){
        if(index == nums.length){
            ans.add(new ArrayList<Integer>(list));
            return;
        }
        //不选第一个数组元素
        findSubsets(nums, index+1);
        //选择第一个数组元素
        list.add(nums[index]);
        findSubsets(nums, index+1);
        list.remove(list.size() - 1);//恢复list为不选的状态，两个分支不会互相影响
    }
}
